<template>
  <div v-loading="loading" class="scan-height">
    <el-scrollbar>
      <div v-for="item in platforms" :key="item.key" class="mb-16">
        <el-card class="border-none mb-16" shadow="none">
          <div class="flex-between">
            <div class="flex align-center">
              <img :src="item.logoSrc" alt="" width="24px" />
              <h5 class="ml-8">{{ item.name }}</h5>
              <el-tag v-if="item.isValid" type="success" class="ml-8"
                >{{ $t('views.system.authentication.scanTheQRCode.effective') }}
              </el-tag>
            </div>
            <div>
              <el-button type="primary" v-if="!item.isValid" @click="showDialog(item)"
                >{{ $t('views.system.authentication.scanTheQRCode.access') }}
              </el-button>
              <span v-if="item.isValid">
                <span class="mr-4">{{
                  item.isActive
                    ? $t('views.system.authentication.scanTheQRCode.alreadyTurnedOn')
                    : $t('views.system.authentication.scanTheQRCode.notEnabled')
                }}</span>
                <el-switch
                  size="small"
                  v-model="item.isActive"
                  :disabled="!item.isValid"
                  @change="changeStatus(item)"
                />
              </span>
            </div>
          </div>
          <el-collapse-transition>
            <div v-if="item.isValid" class="border-t mt-16">
              <el-row :gutter="12" class="mt-16">
                <el-col v-for="(value, key) in item.config" :key="key" :span="12">
                  <el-text class="color-secondary lighter">{{ formatFieldName(key, item) }}</el-text>
                  <div class="mt-4 mb-16 flex align-center">
                    <span
                      v-if="key !== 'app_secret'"
                      class="vertical-middle lighter break-all ellipsis-1"
                      >{{ value }}</span
                    >
                    <span
                      v-if="key === 'app_secret' && !showPassword[item.key]?.[key]"
                      class="vertical-middle lighter break-all ellipsis-1"
                      >************</span
                    >
                    <span
                      v-if="key === 'app_secret' && showPassword[item.key]?.[key]"
                      class="vertical-middle lighter break-all ellipsis-1"
                      >{{ value }}</span
                    >
                    <span>
                      <el-button type="primary" text @click="() => copyClick(value)">
                        <AppIcon iconName="app-copy" />
                      </el-button>
                    </span>

                    <span class="ml-4">
                      <el-button
                        v-if="key === 'app_secret'"
                        type="primary"
                        text
                        @click="toggleShowPassword(item.key)"
                      >
                        <AppIcon
                          iconName="app-password-hide"
                          v-if="key === 'app_secret' && !showPassword[item.key]?.[key]"
                        />

                        <el-icon v-if="key === 'app_secret' && showPassword[item.key]?.[key]">
                          <View />
                        </el-icon> </el-button
                    ></span>
                  </div>
                </el-col>
              </el-row>
              <el-button type="primary" @click="showDialog(item)">
                {{ $t('common.edit') }}
              </el-button>
              <el-button @click="validateConnection(item)">
                {{ $t('views.system.authentication.scanTheQRCode.validate') }}
              </el-button>
            </div>
          </el-collapse-transition>
        </el-card>
      </div>
      <EditModel ref="EditModelRef" @refresh="refresh" />
    </el-scrollbar>
  </div>
</template>

<script setup lang="ts">
import { reactive, ref, onMounted } from 'vue'
import { copyClick } from '@/utils/clipboard'
import EditModel from './EditModal.vue'
import platformApi from '@/api/chat-user/auth-setting.ts'
import { MsgError, MsgSuccess } from '@/utils/message'
import { t } from '@/locales'

interface PlatformConfig {
  [key: string]: string
}

interface Platform {
  key: string
  logoSrc: string
  name: string
  isActive: boolean
  isValid: boolean
  config: PlatformConfig
}

const EditModelRef = ref()
const loading = ref(false)
const platforms = reactive<Platform[]>(initializePlatforms())
const showPassword = reactive<{ [platformKey: string]: { [key: string]: boolean } }>({})

onMounted(() => {
  getPlatformInfo()
})

function initializePlatforms(): Platform[] {
  return [
    createPlatform('wecom', t('views.system.authentication.scanTheQRCode.wecom')),
    createPlatform('dingtalk', t('views.system.authentication.scanTheQRCode.dingtalk')),
    createPlatform('lark', t('views.system.authentication.scanTheQRCode.lark')),
  ]
}

function createPlatform(key: string, name: string): Platform {
  let logo = ''
  switch (key) {
    case 'wecom':
      logo = 'wechat-work'
      break
    case 'dingtalk':
      logo = 'dingtalk'
      break
    case 'lark':
      logo = 'lark'
      break
    default:
      logo = '' // 默认值
      break
  }

  const config = {
    ...(key === 'wecom' ? { corp_id: '', agent_id: '' } : { app_key: '' }),
    app_secret: '',
    callback_url: '',
  }

  return {
    key,
    logoSrc: new URL(`../../../../assets/logo/logo_${logo}.svg`, import.meta.url).href,
    name,
    isActive: false,
    isValid: false,
    config,
  }
}

function formatFieldName(key?: any, item?: Platform): string {
  const fieldNames: { [key: string]: string } = {
    corp_id: 'Corp ID',
    app_key: item?.key != 'lark' ? 'APP Key' : 'App ID',
    app_secret: 'APP Secret',
    agent_id: 'Agent ID',
    callback_url: t('views.application.applicationAccess.callback'),
  }
  return (
    fieldNames[key as keyof typeof fieldNames] ||
    (key ? key.charAt(0).toUpperCase() + key.slice(1) : '')
  )
}

function getPlatformInfo() {
  loading.value = true
  platformApi.getPlatformInfo(loading).then((res: any) => {
    if (res) {
      platforms.forEach((platform) => {
        const data = res.data.find((item: any) => item.auth_type === platform.key)
        if (data) {
          Object.assign(platform, {
            isValid: data.is_valid,
            isActive: data.is_active,
            config: data.config,
          })
          if (platform.key === 'dingtalk') {
            const { corp_id, app_key, app_secret } = platform.config
            platform.config = {
              corp_id,
              app_key,
              app_secret,
              callback_url: platform.config.callback_url,
            }
          }
          showPassword[platform.key] = {}
          showPassword[platform.key]['app_secret'] = false
        }
      })
    }
  })
}

function validateConnection(currentPlatform: Platform) {
  platformApi.validateConnection(currentPlatform, loading).then((res: any) => {
    res.data
      ? MsgSuccess(t('views.system.authentication.scanTheQRCode.validateSuccess'))
      : MsgError(t('views.system.authentication.scanTheQRCode.validateFailed'))
  })
}

function refresh() {
  getPlatformInfo()
}

function changeStatus(currentPlatform: Platform) {
  platformApi.updateConfig(currentPlatform, loading).then((res: any) => {
    MsgSuccess(t('common.saveSuccess'))
  })
}

function toggleShowPassword(platformKey: string) {
  if (!showPassword[platformKey]) {
    showPassword[platformKey] = {}
  }
  showPassword[platformKey]['app_secret'] = !showPassword[platformKey]['app_secret']
}

function showDialog(platform: Platform) {
  EditModelRef.value?.open(platform)
}
</script>

<style lang="scss" scoped>
.scan-height {
  height: calc(100vh - var(--app-header-height) - var(--app-view-padding) * 2 - 70px);
}
</style>
